package main.java.indi.zyj.coderecord;

public class MaxProfit1 {

    public int maxProfit(int[] prices) {

        int len = prices.length;

        if (prices == null || prices.length == 0) return 0;

        // 0表示持有股票的最大金额
        // 1表示持不有股票的最大金额
        int[][] dp = new int[len][2];

        int result = 0;

        dp[0][0] = -prices[0];
        dp[0][1] = 0;

        for (int i = 1; i < len; i++) {
            // 持有
            dp[i][0] = Math.max(-prices[i], dp[i - 1][0]);
            // 不持有 = 昨天就不持有 | 昨天持有，今天卖了股票
            dp[i][1] = Math.max(dp[i - 1][1], dp[i - 1][0] + prices[i]);
        }

        return dp[len - 1][1];

    }

}
